/* *
 * --ライセンスについて--
 *
 * 「本ファイルの内容は Mozilla Public License Version 1.1 (「本ライセンス」)
 * の適用を受けます。
 * 本ライセンスに従わない限り本ファイルを使用することはできません。
 * 本ライセンスのコピーは http://www.mozilla.org/MPL/ から入手できます。
 *
 * 本ライセンスに基づき配布されるソフトウェアは、「現状のまま」で配布されるものであり、
 * 明示的か黙示的かを問わず、いかなる種類の保証も行われません。
 * 本ライセンス上の権利および制限を定める具体的な文言は、本ライセンスを参照してください。
 *
 * オリジナルコードおよび初期開発者は、N_H (h.10x64@gmail.com) です。
 *
 * N_H によって作成された部分の著作権表示は次のとおりです。
 *
 * Copyright (C)N_H 2012
 *
 * このファイルの内容は、上記に代えて、
 * GNU General License version2 以降 (以下 GPL とする)、
 * GNU Lesser General Public License Version 2.1 以降 (以下 LGPL とする)、
 * の条件に従って使用することも可能です。
 * この場合、このファイルの使用には上記の条項ではなく GPL または LGPL の条項が適用されます。
 * このファイルの他者による使用を GPL または LGPL の条件によってのみ許可し、
 * MPL による使用を許可したくない対象者は、上記の条項を削除することでその意思を示し、
 * 上記条項を GPL または LGPL で義務付けられている告知およびその他の条項に置き換えてください。
 * 対象者が上記の条項を削除しない場合、
 * 受領者は MPL または GPL または LGPL ライセンスのいずれによってもこのファイルを
 * 使用することができます。」
 *
 * -- License --
 *
 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
 *
 * The contents of this file are subject to the Mozilla Public License Version
 * 1.1 (the "License"); you may not use this file except in compliance with
 * the License。You may obtain a copy of the License at
 * http://www.mozilla.org/MPL/
 *
 * Software distributed under the License is distributed on an "AS IS" basis,
 * WITHOUT WARRANTY OF ANY KIND、either express or implied。See the License
 * for the specific language governing rights and limitations under the
 * License.
 *
 * The Initial Developer of the Original Code is
 *   N_H (h.10x64@gmail.com).
 *
 * Portions created by the Initial Developer are Copyright (C)N_H 2012
 * the Initial Developer。All Rights Reserved.
 *
 * Alternatively、the contents of this file may be used under the terms of
 * either the GNU General Public License Version 2 or later (the "GPL")、or
 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
 * in which case the provisions of the GPL or the LGPL are applicable instead
 * of those above。If you wish to allow use of your version of this file only
 * under the terms of either the GPL or the LGPL、and not to allow others to
 * use your version of this file under the terms of the MPL、indicate your
 * decision by deleting the provisions above and replace them with the notice
 * and other provisions required by the GPL or the LGPL。If you do not delete
 * the provisions above、a recipient may use your version of this file under
 * the terms of any one of the MPL、the GPL or the LGPL.
 *
 * */
package com.magiciansforest.audio.soundrenderer;

import com.jme3.asset.plugins.FileLocator;
import com.jme3.bullet.PhysicsSpace;
import com.jme3.light.AmbientLight;
import com.jme3.math.Vector3f;
import com.magiciansforest.audio.soundrenderer.gui.MovieDataInterface;
import com.magiciansforest.audio.soundrenderer.logic.Movie;
import com.magiciansforest.audio.soundrenderer.logic.MovieFile;
import com.magiciansforest.audio.soundrenderer.logic.sound.AudioRenderThread;
import de.lessvoid.nifty.Nifty;
import de.lessvoid.nifty.screen.DefaultScreenController;
import java.io.File;
import java.io.IOException;
import java.util.Enumeration;
import java.util.logging.Level;
import java.util.logging.LogManager;
import java.util.logging.Logger;
import javax.script.ScriptException;
import javax.sound.sampled.LineUnavailableException;

/**
 *
 * @author TB
 */
public class Viewer extends ApplicationBase {

    public static final String LOGGER_NAME = "3DSound4MMD";
    public static final double MMD_UNIT_SIZE = 0.1;
    private Movie mov;
    private boolean logEnabled;

    public Viewer(int width, int height, boolean logEnabled) throws IOException, LineUnavailableException {
        super(width, height);
        this.mov = new Movie(this);
        this.logEnabled = logEnabled;
        AudioRenderThread.getAudioRenderThread().setUnitSize(MMD_UNIT_SIZE);
    }

    @Override
    public void simpleInitApp() {
        super.simpleInitApp();
        
        assetManager.registerLocator("./assets", FileLocator.class);
        
        PhysicsSpace ps = new PhysicsSpace(PhysicsSpace.BroadphaseType.DBVT);
        System.out.println("ps" + ps);
        ps.enableDebug(assetManager);

        if (!logEnabled) {
            LogManager logManager = LogManager.getLogManager();
            if (logManager != null) {
                Enumeration<String> loggerNames = logManager.getLoggerNames();
                while (loggerNames.hasMoreElements()) {
                    String loggerName = loggerNames.nextElement();
                    Logger.getLogger(loggerName).setLevel(Level.SEVERE);
                }
            }
        }
        rootNode.addLight(new AmbientLight());

        cam.setLocation(new Vector3f(0, 12, 35));
        cam.setFrustumFar(10000);

        //Setup NiftyGUI
        Nifty nifty = getNifty();
        if (!logEnabled) {
            Logger.getLogger("de.lessvoid.nifty").setLevel(Level.SEVERE);
            Logger.getLogger("NiftyInputEventHandlingLog").setLevel(Level.SEVERE);
        }
        //Create ScreenControllers
        MovieDataInterface ctrl = new MovieDataInterface();
        ctrl.setMovie(mov);
        nifty.registerScreenController(new DefaultScreenController(), ctrl);
        //Load default settings
        nifty.loadStyleFile("nifty-default-styles.xml");
        nifty.loadControlFile("nifty-default-controls.xml");
        //Load screen
        nifty.fromXml("GUI/gui.xml", "init");
    }
}
